-
-
Notifications
You must be signed in to change notification settings - Fork 188
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add HP Z220 CMT #1399
Add HP Z220 CMT #1399
Conversation
config/linux-x230-maximized.config
Outdated
@@ -330,3 +330,4 @@ CONFIG_CRC8=m | |||
CONFIG_XZ_DEC_TEST=m | |||
CONFIG_CORDIC=m | |||
CONFIG_IRQ_POLL=y | |||
CONFIG_BLK_DEV_NVME=y |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If NVME is NEEDED (not the case for xx20/xx30) one could either modify init to load board an additionally exported and board defined variable to load additional hardware support conditionally, have it enabled here as module (=m) and have modules/linux pack it under modules.cpio for initrd.cpio.xz on demand for that newly added board variable (CONFIG_ENABLE_NVME=y).
But adding it for all xx20/xx30 is not desired across all boards depending on that linux-x230-maximized.config today.
One could also duplicate linux-x230-maximized.config for another board as well.
Another pending PR addressed this concern.
It is simply impossible to accept other boards needs under x230 for the moment, considering other modules needing merging (gnupg, flashrom etc) and other smaller board's SPI limitation as of today (linux-x230-maximized is used by xx20 boards, which all have 8mb SPI chips).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I assume you're referring to #956 ? Yeah, one would be pretty hard pressed to add that in if we're just considering the x230 (there is room for one with an adapter in the WWAN slot but I don't think it's wired up for NVME sadly).
Is it possible to have another config file that basically only has two lines, one to enable NVME and one to point to the xx30 config? I see some (not all) of the files in /board do this but none in /config.
#1282 seperated the t440p config altogether, to remove nvme support from duplicated librem_common config. We COULD add nvme for all xx20/xx30 boards, but that PR will get merged only after 5.10.5 is common for all boards. Please clean it up so that there is limited number of commits to match needed changes in tree. |
I replied at #956 (comment) |
It would be possible to create snippets of kernel configs requirements for some functions, yes, and then modify modules/linux and board config parsing to take into consideration those options and concatenate those function files into a "linux config" file currently expected to be pointed to modules/linux through the board config file. As of now, I'm not sure how to deal with this properly. My current thought process is to drop defconfig file format for linux configurations (and maybe even for coreboot which otherwise hide important details to the end user since most of the options stating blob status and everything else is currently hidden into defaults hidden through defconfig format which is just deviation to the defaults for a specific commit of coreboot/linux) which is why I am bringing helpers for the modules/linux module to pass from one format to the other so that users/developers can easily compare the files across versions and across boards. |
I would expect desktops to be able to work with more generic kernel configs than the kernel, so maybe the X230 config can be copied into a kind of common desktop Sandy/Ivy Bridge config? In that case I'd suggest naming it linux-p8z77.config (or otherwise maybe linux-sandy-bridge-desktop-8MB.config), better reflecting the 8MB target which I expect to be much less rare than 16MB and which the current X230 config meets regardless. If needed maybe split that again in the future into a linux-z220.config for the boards that support 16MB images.
Will see what I can do.
Much of this is greek to me haha. Sorry. |
07d81e2
to
0d81285
Compare
Sorry, my bad. Coreboot and Linux pushed forward defconfig format, which is tiny config letting the user know what is the differences in regard of the default configuration for a specific version used. Oldconfig is full config, permitting to inspect for what the config actually included and excluded, as opposed to referring to the defaults to know what derived. |
I see you forced pushed. Good. I do not own the board. That means testing when coreboot and Linux version bumps happen. And that means as well detailing the setup you used that worked for you. That is normally added into the board configuration. You can take a look at desktop boards, which detail more then laptops which are expected to all have the same hardware. |
That should be okay, assuming you don't mind if there's a delay of e.g. maybe a few days at times.
I guess that's the CPU, (d)GPU, maybe RAM and OS? btw my questions about the VSCC and TOTP above still stand. I don't know if you can say much about the former but I think you're in a good position to answer the latter. And assuming I'm going to indeed make a new kernel config for nvme like suggested which name for it would you prefer (see above)? |
@d-wid sorry for the delay!
I'm not sure I follow. When you add a key to firmware, you are modifying the firmware by injecting a file through a cbfs operation. On next boot, you have to reseal TOTP (and HOTP) so that the sealed secret, transformed into QR coe and scanned under smartphone, can be used to validate firmware measurements. Normally, PCR2 won't change there, but user configs will. See https://osresearch.net/Keys/#tpm-pcrs. Then if you say that unsealing fails randomly, that deserves more explanations. Going into the recovery and looking at tpm values under /sys would give you a clear view of what is happening here.
That would be a question to address to the author of that script. I think it is a nice addition, if it works, since as noted in that original PR, it changes what ME can write into. Other then that, i'm not extremely familiar with the concepts there, preaching for hardware (i know, old) that have ME neutered, so ME cannot do anything really. I would suggest poking the author directly here so that knowledge transfe happens between the authors for ther boards.
Yes. CPU, dgpu and ram (dmidecode reported) would be enough, giving info on ram speed, cpu family etc. |
I decided to make a new Linux config and name it C216 (the Z220's chipset). However, it should obviously also work for Z77 boards. Maybe switch the Linux config of that board too if you're okay with the Z220 being handled this way? |
@d-wid following Linux output for tis TPM, it seems that you have a 2.0 TPM variant? With a thumb drive connected: Upload the logs here please. |
|
Ideal would be to From the recovery shell. When unsealing works and then when unsealing doesn't, and also report the above when it doesn't. |
pcrs-success.txt An earlier coreboot.log from a failed TOTP unseal (unfortunately the TCPA log from this attempt got lost for some reason): |
Well, seems like the board will need the option to delay the TPM init. By comparing success and fail pcrs, pcr2 is empty when failing, which means coreboot is not able to do its measurements (see wiki for TPM pcrs). |
Where do I configure that (and by how much)? (I'm looking for it but haven't found it yet) |
On master, coreboot module bas an helper permitting you to modify configuration (menuconfig) from thé coreboot config and save it back in oldconfig format See https://github.com/osresearch/heads/blob/master/modules/coreboot#L177 That is make BOARD=xyz coreboot.nameofhelper |
I suppose whatever is done there would be equivalent to adding the CONFIG_TPM_RDRESP_NEED_DELAY=y line I found in the Opteron board's coreboot config? |
If the board supports it through Kconfig settings, yes. Which is why using menuconfig on the config and saving it back would confirm this, otherwise the option would not be available. |
Looks like it does. I'll see if it works. |
Yes.. When it fails (third coreboot log provided):
|
I added the line and I've not been able to reproduce the problem since (felt like it had been decreasing in frequency recently on the build I used without it anyway, but had never disappeared like it seems to have right now). Great. |
config/linux-x230-maximized.config
Outdated
CONFIG_IRQ_POLL=y |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is irrelevant. Please clean commit trace removing changes to linux-x230-maximized.config
733f0d8
to
9d2074f
Compare
The dGPU isn't used before Heads hands over to another Linux OS, no. That's why the iGPU is set as primary in the Coreboot config. I don't intend to have Heads run on an dGPU.
As long as whatever is kexec'd into can itself use the dGPU I should be fine. If I understannd correctly my system should be equivalent to an X230 with an Expresscard eGPU in that sense.
(If anyone reading this is interested there is a config I made last year for my P8Z77V that did eventually seem to work with the dGPU but only in text mode and only for Radeon anyway. I couldn't get around the interface in that form and gave up)
|
The board configuration should then be clearer for that use case. Maybe the board name should even specify iGPU in its name? The reason I'm insisting on this is that pending PR will reactivate libgfxinit for coreboot config on x230, pass proper options to heads Linux payload for it to expose its framebuffer address which is then passed through kexec call so that even OS only providing vesa framebuffer at early boot provides a working console. That is, x230 will show a bootsplash early at boot through libgfxinit until payload is read from SPI, measured and booted into and that i915drmfb drives the iGPU for which framebuffer is reused at kexec call for final OS. Trying to do the same for dGPU under Heads will require lots of effort. libgfxinit can only drive GMA that is Intel iGPU on coreboot side, and the issues that were opened in the past for "black screen at kexec" are a result of that: if Heads graphic framebuffer cannot be reused per final OS at early boot, then the final OS might be asking for decryption passphrase without proper graphic drivers having took ownership of the console at that point. And since Linux changed a lot between kernel 4.14 and 6, it cannot be expected that the framebuffer address is exposed to next kernel at kexec call. Tldr: nice that this board is iGPU driven by i915drmfb driver just like the x230. But it should be clarified as such in board name/board config since most users would probably expect their dGPU to work out of the box. Longer term: dGPU working out of the box won't be magically accomplished unless coreboot implements some kind of UEFI GOP equivalent under libgfxinit for it to support basically other dGPU, where Linux simplefb could theoritically be reused there with fbwhiptail working with that simple framebuffer, letting the OS activate 3d acceleration through their more advanced DRM+fb drivers. |
I expect you supporting a Z220 with an iGPU (i.e. same as the Z77) to be sufficient for me, much like I expect to be able to get an eGPU to work on an X230 with Heads if I were to have the Hardware. Being able to get here is why I got a 1275v2 in the first place (I should get to seeling my 1230v2 at some point...)
It's probably worth stating that the only way this config diverges from the already merged Z77 config and the X230 with regards to graphics is enabling CONFIG_ONBOARD_VGA_IS_PRIMARY=y.
Oh and yes, all the above screenshots are from i915. Like I said the config in this PR doesn't have Heads drive the dGPU (any more than the other Ivy Bridge configs would), it just isn't disturbed by its presence either.
|
Does this mean that my setup (dGPU being called AFTER kexec) won't work at all because of libgfxinit? In that case, maybe a -dgpu board variant with libgfxinit disabled (retaining the X230's current setting), with the default settings with libgfxinit not being given any suffixes (just like the normal X230, Z77, etc boards)?
Otherwise, as it is now I slightly doubt the dGPU works "out of the box" anyway.
What happens now is that (presumably with the help of kernel command lines I've known in the past to stop i915 from loading X) the iGPU remains in use after kexec until X (or in my case GNOME Wayland) gets loaded, after which I manually switch my monitor to display the input from the dGPU instead.
Which is to say that the config in this PR is as much configured for the iGPU as the X230, Z77, etc configs in master anyway, it's just possible to (somewhat jankily) make a dGPU work within this setting.
I'm not sure libgfxinit is going to ruin that, but I guess I'll just test that after that PR gets merged (and if it does create another Z220 config with libgfxinit disabled?)
…On 29 June 2023 13:21:45 UTC, tlaurion ***@***.***> wrote:
The board configuration should then be clearer for that use case. Maybe the board name should even specify iGPU in its name?
The reason I'm insisting on this is that pending PR will reactivate libgfxinit for coreboot config on x230, pass proper options to heads Linux payload for it to expose its framebuffer address which is then passed through kexec call so that even OS only providing vesa framebuffer at early boot provides a working console.
That is, x230 now shows a bootsplash early at boot through libgfxinit, then i915drmfb drives the iGPU for which framebuffer is reused at kexec call for final OS.
Trying to do the same for dGPU under Heads will require lots of effort. libgfxinit can only drive GMA that is Intel iGPU on coreboot side, and the issues that were opened in the past for "black screen at kexec" are a result of that: if Heads graphic framebuffer cannot be reused per final OS at early boot, then the final OS might be asking for decryption passphrase without proper graphic drivers having took ownership of the console at that point. And since Linux changed a lot between kernel 4.14 and 6, it cannot be expected that the framebuffer address is exposed to next kernel at kexec call.
Tldr: nice that this board is iGPU driven by i915demfb driver just like the x230. But it should be clarified as such since most users would probably expect their dGPU to work out of the box.
Longer term: dGPU working out of the box won't be magically accomplished unless coreboot implements some kind of UEFI GOP equivalent under libgfxinit for it to support basically other dGPU, where Linux simplefb could theoritically be reused there with fbwhiptail working with that simple framebuffer, letting the OS activate 3d acceleration through their more advanced DRM+fb drivers.
--
Reply to this email directly or view it on GitHub:
#1399 (comment)
You are receiving this because you were mentioned.
Message ID: ***@***.***>
|
@d-wid it should be all good, bootsplash shown on i915 driver driven main screen and dgpu unperturbed. Coreboot should discover PCI and pass info to OS as usual, no change there. And then OS can drive dGPU. But board config should specify clearly that onboard VGA only is driven by heads. As of now I'm only aware of you using that platform. And it should be clear what is the use case here for people that will use this board, otherwise open issues and poke you in the future! |
f0630b9
to
473c235
Compare
da657da
to
a3a7f79
Compare
@tlaurion Apologies also for the delay, I'd been waiting on the other motherboards not realising their new configs had already been merged a week ago. Anyway I've just built the most recent commit of this fork and it works for what I used my older Z220 Heads builds for i.e. boot, TPMTOTP, and then an ISO on the flash disk. The new splash image functionality also works. |
@d-wid your coreboot configuration doesn't include proper config options to enable platform locking as defined under https://github.com/osresearch/heads/blob/473c235fbaf56698aa9beefd2684fbf7d4499809/initrd/bin/lock_chip header. |
Should be fixed now.
|
@tlaurion I don't foresee being able to make the resync to master commit disappear, I hope that's okay?
|
@d-wid Unfortunately, the commit trace should be cleaner, i'm sorry... At this point all of those commits could be squashed into one: Add HP Z220 CMT. Maybe I could help you do this on the command line if you reached out to the heads community channel or to me through matrix? |
fec63b3
to
66ef5c3
Compare
@tlaurion Hi, I could squash everything after all. My worry was that that I had issues trying that with a resync-to-master commit I'd done through github in the way.
Just now I decided to just remove the resync-related commits and try (successfully) to squash everything again after that. I'm just hoping I won't have to re-base with a new Coreboot and Linux version again like what happened preceding this one.😅
|
@tlaurion Great! Unfortunately I've not been in a position to boot the #1400 Z77 board for some time now and for the foreseeable future. I could "port" the config over to the current Linux and Coreboot versions like for the Z220 but I won't test it (not as much as my now main PC Z220 any time soon in any case), so I guess it'll be abandoned until someone (else) who uses the Z77-V shows up. Would you suggest closing it or leaving it as a draft? (strictly speaking it being merged at some point is not ruled out after all)
Will test again if/when #1403 merges, exam schedule permitting.
|
The comments from @ThePlexus about the P8Z77 apply here as well, but with a soldered TPM 1.2 and 16MB BIOS ROM chip and a chipset that supports ECC RAM.
I don't know if this is the case with other boards, but on the builds I've made based on https://github.com/osresearch/heads/tree/1f90d2b8e16226fced94b8ab3c93f58a483b7e6d the TPM TOTP secret unseal often fails after a reboot post-flashing (e.g. after adding a GPG key). Going into the settings and selecting the flash current configuration item and then going through the TPM owning process after the flash seems to fix it so that the ability to unseal the secret can survive a reboot. Even then the unseal still does fail sometimes, but at this point it should be nothing a REISUB/REISUO or two can't fix. HOTP pretty much untested.
I don't know where to begin with the VSCC table modification part of the blob download script so I just commented it out and removed it. Do I want to add it back in as verbatim copy of the P8Z77 version, or should it be modified?
I feel like I also improved the TOTP situation by removing the ME override/password jumpers (if done after the vendor BIOS is replaced it's still possible to flash the whole chip afterwards) so maybe there's some influence from one of them, though this might be pure placebo.
I haven't tested the ethernet connection, but since I did find information that it uses the same hardware as the X230 I just pointed to its GbE blob.
I haven't tried removing the nohz=off command, just left it there from the P8Z77 configs.
Apologies for uploading this in the middle of moving
bothLinuxand Corebootversions from what's used here.